HEX
Server: Apache/2.4.58 (Ubuntu)
System: Linux ip-172-26-0-120 6.17.0-1009-aws #9~24.04.2-Ubuntu SMP Fri Mar 6 23:50:29 UTC 2026 x86_64
User: ubuntu (1000)
PHP: 8.3.6
Disabled: NONE
Upload Files
File: /var/www/html/owlcrm/app/Http/Controllers/admin/RoleController.php
<?php

namespace App\Http\Controllers\admin;

use App\Models\SuperRole;
use Yajra\DataTables\Facades\DataTables;
use Validator;
use Illuminate\Validation\Rule;
use App\Http\Controllers\Controller;
use App\Models\AdminSuperRoles;
use App\Models\Module;
use App\Models\SuperRolePermission;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

class RoleController extends Controller
{
    /**
     * Display a listing of the resource.
     */
    public function index(Request $request)
    {

        if ($request->ajax()) {
            $search_keyword = '';

            $request_data = $request->all();
            if ($request->has('search_keyword')) {
                $search_keyword = $request->search_keyword;
            }
            // avoid zero column as it's checkbox so we can't sort by it
            if ($request->has('order') && $request->order[0]['column'] != 0) {
                $sort_column_number = $request->order[0]['column'];
                $sort_column_dir = $request->order[0]['dir'];
                $sort_column_key = $request->columns[$sort_column_number]['data'];
            }

            $main_query = SuperRole::query();
            $query = $main_query;
            if (!empty($search_keyword)) {
                $query = $query->where('name', 'LIKE', '%' . $search_keyword . '%');
            }
            if (!empty($sort_column_key)) {
                $query = $query->orderBy($sort_column_key, $sort_column_dir);
            } else {
                $query = $query->latest();
            }

            $data = $query->get();
            $count_total = $main_query->count();
            $count_filter = $count_total;
            return DataTables::of($data)

                ->addColumn('name', function ($row) {
                    return $row->name;
                })
                ->addColumn('description', function ($row) {
                    return $row->description;
                })
                ->addColumn('action', function ($row) {

                    return view('admin.roles.partially.delete', compact('row'));
                })

                ->rawColumns(['action'])
                ->with([
                    "recordsTotal"    => $count_total,
                    "recordsFiltered" => $count_filter,
                ])
                ->make(true);
        }

        return view('admin.roles.index');
    }

    /**
     * Show the form for creating a new resource.
     */
    public function create()
    {
        $modules = Module::with('permissions')->get();



        return view('admin.roles.create', ['modules' => $modules]);
    }

    /**
     * Store a newly created resource in storage.
     */
    public function store(Request $request)
    {
        $validator = Validator::make($request->all(), [
            'name' => ['required', 'string', 'unique:' . SuperRole::class],
            'description' => 'required|string',
        ]);
        if ($validator->fails()) {
            return redirect()->back()->withErrors($validator)->withInput();
        }

        DB::beginTransaction();
        try {
            $role = new SuperRole();
            $role->name = $request->input('name');
            $role->description = $request->input('description');
            $role->save();



            $permissions = $request->input('permission');

            if (count($permissions)) {
                foreach ($permissions as $permission) {
                    $role_permission = new SuperRolePermission();
                    $role_permission->role_id = $role->id;
                    $role_permission->permission_id = $permission;
                    $role_permission->save();
                    DB::commit();
                }
            }

            return redirect()->route('roles.index')->with('success', 'Role added Successfully');
        } catch (\Exception $e) {
            DB::rollback();
            return response()->json(['success' => false, 'message' => $e->getMessage()]);
        }
    }

    /**
     * Display the specified resource.
     */
    public function show(string $id)
    {
        //
    }

    /**
     * Show the form for editing the specified resource.
     */
    public function edit(string $id)
    {
        $role = SuperRole::with('rolePermissions')->find($id);

        $role_permission = [];
        if (count($role->rolePermissions)) {

            $role_permission = $role->rolePermissions->pluck('permission_id')->toArray();
        }
        $modules = Module::with('permissions')->get();
        if (isset($role)) {
            return view('admin.roles.edit', ['role' => $role, 'modules' => $modules, 'role_permission' => $role_permission]);
        } else {
            return back()->with('error', 'Role does not exist');
        }
    }

    /**
     * Update the specified resource in storage.
     */
    public function update(Request $request, string $id)
    {
        $validator = Validator::make($request->all(), [
            'name' => ['required', 'string',  Rule::unique('super_roles')->ignore($id)],
            'description' => 'required|string',

        ]);

        if ($validator->fails()) {
            return redirect()->back()->withErrors($validator)->withInput();
        }


        DB::beginTransaction();
        try {
            $role = SuperRole::find($id);
            if (isset($role)) {
                $role->name = $request->input('name');
                $role->description = $request->input('description');
                $role->save();

                $permissions = $request->input('permission');
                if (count($permissions)) {
                    SuperRolePermission::where('role_id', $id)->delete();
                    foreach ($permissions as $permission) {

                        $role_permission = new SuperRolePermission();
                        $role_permission->role_id = $role->id;
                        $role_permission->permission_id = $permission;
                        $role_permission->save();
                        DB::commit();
                    }
                }

                return redirect()->route('roles.index')->with('success', 'Role has been updated successfully.');
            } else {
                return back()->with('error', 'Role not found.');
            }
        } catch (\Exception $e) {
            DB::rollback();
            return response()->json(['success' => false, 'message' => $e->getMessage()]);
        }
    }

    /**
     * Remove the specified resource from storage.
     */
    public function destroy(string $id)
    {
        $role = SuperRole::find($id);
        if (isset($role)) {
            $role->delete();
            SuperRolePermission::where('role_id', $id)->delete();
            // for delete role_id in AdminSuperRoles migration
            $adminSuperRole = AdminSuperRoles::where('role_id', $id)->delete();
            return redirect()->back()->with('success', 'Role has been deleted successfully.');
        } else {
            return back()->with('error', 'Role not found.');
        }
    }
}